---
title: Користувацькі гаманці
description: Створіть користувацький гаманець
---

# Користувацькі гаманці

## Створіть користувацький гаманець

> Примітка: Це API нестабільний і швидше за все зміниться найближчим часом. Ми будемо додавати більше вбудованих гаманців з часом. [Повідомте нам](https://github.com/rainbow-me/rainbowkit/issues), якщо вас цікавлять якісь конкретні гаманці.

Тип функції `Wallet` надається, щоб допомогти вам визначити власні користувацькі гаманці. Наступні властивості можуть бути налаштовані на значення, яке повертається функцією `Wallet`:

### Властивості гаманця

<PropsTable
  data={[
    {
      name: 'id',
      required: true,
      type: 'string',
      description: 'Унікальний ID для кожного гаманця',
    },
    {
      name: 'name',
      required: true,
      type: 'string',
      description: 'Зрозуміла людині назва гаманця',
    },
    {
      name: 'rdns',
      required: false,
      type: 'string',
      description: 'RDNS для гаманця, який підтримує EIP6963',
    },
    {
      name: 'shortName',
      required: false,
      type: 'string | undefined',
      description: 'Необов\'язкова коротка назва для мобільного використання',
    },
    {
      name: 'iconUrl',
      required: true,
      type: 'string | (() => Promise<string>)',
      description:
        'URL для іконки гаманця або обіцянка, що розв\'язується в Base64 data URL',
    },
    {
      name: 'iconAccent',
      required: false,
      type: 'string',
      description:
        'Акцентний колір для потоків завантаження для гаманців з розширенням браузера та мобільним додатком',
    },
    {
      name: 'iconBackground',
      required: true,
      type: 'string',
      description: 'Колір фону під час завантаження іконки гаманця',
    },
    {
      name: 'installed',
      required: false,
      type: 'boolean | undefined',
      description: (
        <>
          Чи відомо, що гаманець встановлено, або{' '}
          <code>undefined</code>, якщо невизначено
        </>
      ),
    },
    {
      name: 'downloadUrls',
      required: false,
      type: '{ android?: string, ios?: string, mobile?: string, qrCode?: string, chrome?: string, firefox?: string, edge?: string, safari?: string, opera?: string, browserExtension?: string } | undefined',
      typeSimple: 'DownloadUrls | undefined',
      description: 'Об\'єкт, що містить URL-адреси для завантаження',
    },
    {
      name: 'hidden',
      required: false,
      type: '(args: { wallets: Array<{ id: string, connector: Connector, installed?: boolean }> }) => boolean',
      typeSimple: '(args) => boolean | undefined',
      description:
        'Функція для обчислення, чи слід приховати цей гаманець зі списку. Це корисно для визначення загальних резервних гаманців, наприклад, вбудований резервний "Ін\'єктований гаманець" використовує цю функцію',
    },
    {
      name: 'createConnector',
      required: true,
      type: '() => RainbowKitConnector',
      typeSimple: 'RainbowKitConnector',
      description:
        'Функція для надання екземпляра з\'єднувача та конфігурації для різних методів підключення, описаних нижче',
    },
    {
      name: 'mobile',
      required: false,
      type: '{ getUri?: (uri: string) => string }',
      typeSimple: 'object',
      description:
        'Функція для розв\'язання URI підключення мобільного гаманця',
    },
    {
      name: 'desktop',
      required: false,
      type: '{ getUri?: (uri: string) => string }',
      typeSimple: 'object',
      description: 'Функція для розв\'язання глибокого посилання настільного додатка',
    },
    {
      name: 'qrCode',
      required: false,
      type: "{ getUri: (uri: string) => string, instructions?: { learnMoreUrl: string, steps: Array<{ step: 'install' | 'create' | 'scan', title: string, description: string }> }}}",
      typeSimple: 'object',
      description:
        'Об\'єкт, що містить функцію для розв\'язання URI QR-коду, плюс необов\'язкові інструкції з налаштування мобільного гаманця',
    },
    {
      name: 'extension',
      required: false,
      type: "{ instructions?: { learnMoreUrl: string, steps: Array<{ step: 'install' | 'create' | 'scan', title: string, description: string }> }}}",
      typeSimple: 'object',
      description:
        'Об\'єкт, що містить необов\'язкові інструкції з налаштування розширення браузера',
    },
    {
      name: 'createConnector',
      required: true,
      type: "createConnector: (details: WalletDetailsParams) => CreateConnectorFn",
      typeSimple: '(details: WalletDetailsParams) => CreateConnectorFn',
      description: 'Функція для надання екземпляра з\'єднувача',
    },
  ]}
/>

### Властивості DownloadUrls

<PropsTable
  data={[
    {
      name: 'android',
      required: false,
      type: 'string',
      description: 'URL Google Play',
    },
    {
      name: 'ios',
      required: false,
      type: 'string',
      description: 'URL Apple App Store',
    },
    {
      name: 'mobile',
      required: false,
      type: 'string',
      description:
        'Лендингова сторінка для мобільних користувачів, коли `android` або `ios` недоступні',
    },
    {
      name: 'qrCode',
      required: false,
      type: 'string',
      description:
        'Лендингова сторінка для користувачів, які сканують QR-код завантаження мобільного додатка',
    },
    {
      name: 'chrome',
      required: false,
      type: 'string',
      description: 'URL Chrome Web Store',
    },
    {
      name: 'edge',
      required: false,
      type: 'string',
      description: 'URL Microsoft Edge Add-ons',
    },
    {
      name: 'firefox',
      required: false,
      type: 'string',
      description: 'URL Firefox Browser Add-ons',
    },
    {
      name: 'opera',
      required: false,
      type: 'string',
      description: 'URL для розширень Opera',
    },
    {
      name: 'safari',
      required: false,
      type: 'string',
      description: 'URL Mac App Store',
    },
    {
      name: 'browserExtension',
      required: false,
      type: 'string',
      description:
        'Лендингова сторінка для користувачів настільних розширень, коли URL-адреси, сумісні з браузером, недоступні',
    },
  ]}
/>

### Приклади

Наприклад, щоб створити користувацький гаманець з використанням WalletConnect:

```tsx
import { Wallet, getWalletConnectConnector } from '@rainbow-me/rainbowkit';

export interface MyWalletOptions {
  projectId: string;
}

export const rainbow = ({ projectId }: MyWalletOptions): Wallet => ({
  id: 'my-wallet',
  name: 'My Wallet',
  iconUrl: 'https://my-image.xyz',
  iconBackground: '#0c2f78',
  downloadUrls: {
    android: 'https://play.google.com/store/apps/details?id=my.wallet',
    ios: 'https://apps.apple.com/us/app/my-wallet',
    chrome: 'https://chrome.google.com/webstore/detail/my-wallet',
    qrCode: 'https://my-wallet/qr',
  },
  mobile: {
    getUri: (uri: string) => uri,
  },
  qrCode: {
    getUri: (uri: string) => uri,
    instructions: {
      learnMoreUrl: 'https://my-wallet/learn-more',
      steps: [
        {
          description:
            'We recommend putting My Wallet on your home screen for faster access to your wallet.',
          step: 'install',
          title: 'Open the My Wallet app',
        },
        {
          description:
            'After you scan, a connection prompt will appear for you to connect your wallet.',
          step: 'scan',
          title: 'Tap the scan button',
        },
      ],
    },
  },
  extension: {
    instructions: {
      learnMoreUrl: 'https://my-wallet/learn-more',
      steps: [
        {
          description:
            'We recommend pinning My Wallet to your taskbar for quicker access to your wallet.',
          step: 'install',
          title: 'Install the My Wallet extension',
        },
        {
          description:
            'Be sure to back up your wallet using a secure method. Never share your secret phrase with anyone.',
          step: 'create',
          title: 'Create or Import a Wallet',
        },
        {
          description:
            'Once you set up your wallet, click below to refresh the browser and load up the extension.',
          step: 'refresh',
          title: 'Refresh your browser',
        },
      ],
    },
  },
  createConnector: getWalletConnectConnector({ projectId }),
});
```

Потім ви можете додати свій власний гаманець до [списку гаманців](/docs/custom-wallet-list).
